<?xml version="1.0" encoding="UTF-8"?>
<!--
To change this license header, choose License Headers in Project Properties.
To change this template file, choose Tools | Templates
and open the template in the editor.
-->
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:ui="http://xmlns.jcp.org/jsf/facelets"
      xmlns:h="http://xmlns.jcp.org/jsf/html"
      xmlns:p="http://primefaces.org/ui"
      xmlns:f="http://xmlns.jcp.org/jsf/core">

    <ui:composition template="/template.xhtml">
        <ui:define name="title">
            <h:outputText value="Accesos"></h:outputText>
        </ui:define>

        <ui:define name="cuerpo">
            <p:growl id="message" showDetail="true" />
            <h:form id="form">
                <p:growl id="validacionMensaje" showDetail="true" autoUpdate="true"/>
                <p:panel header="Administración de Roles" style="font-size: small">
                    <table width="100%" border="0" >
                        <p:commandButton value="Crear" style="font-size: small" action="#{rolBean.cargarNuevo()}" 
                                         icon="ui-icon-circle-plus"
                                         update="@form:dlDialog" oncomplete="PF('dlDialogVar').show()"
                                         process="@this">
                        </p:commandButton>        
                    </table>

                    <p:dataTable id="dtRoles" var="rolItem" value="#{rolBean.roles}" widgetVar="tablaRoles"                                                                  
                                 emptyMessage="No existen datos"
                                 style="margin-top: 10px; font-size: x-small; text-align: center"                                
                                 paginator="true" rows="10" rowKey="#{rolItem.codRol}">

                        <f:facet name="header">
                            <p:outputPanel>
                                <h:outputText value="Buscar por todos los criterios:" />
                                <p:inputText id="globalFilter" onkeyup="PF('tablaRoles').filter()" 
                                             style="width:200px" placeholder="Ingrese la palabra clave"/>
                            </p:outputPanel>
                        </f:facet>

                        <p:column headerText="Nombre" filterBy="#{rolItem.nombre}">
                            <p:outputLabel value="#{rolItem.nombre}" style="text-align: center"/>
                        </p:column>

                        <p:column headerText="Descripcion" filterBy="#{rolItem.descripcion}">
                            <p:outputLabel value="#{rolItem.descripcion}" style="text-align: center"/>
                        </p:column>

                        <p:column headerText="Herramientas" >                                                        
                            <div align="center">

                                <p:commandButton value="Modificar" action="#{rolBean.cargarModificar()}" update="@form:dlDialog" 
                                                 oncomplete="PF('dlDialogVar').show()" process="@this">
                                    <f:setPropertyActionListener value="#{rolItem}" target="#{rolBean.rol}" />
                                </p:commandButton>  | 

                                <p:commandButton value="Detalles" action="#{rolBean.cargarDetalles()}" update="@form:dlDialog:" 
                                                 oncomplete="PF('dlDialogVar').show()" process="@this">
                                    <f:setPropertyActionListener value="#{rolItem}" target="#{rolBean.rol}" />
                                </p:commandButton>                                

                            </div>
                        </p:column> 

                    </p:dataTable>
                </p:panel>

                <p:dialog id="dlDialog" resizable="false" header="#{rolBean.tituloDialogo}"  appendTo="@(body)"
                          widgetVar="dlDialogVar" modal="true" showEffect="fade" hideEffect="fade" dynamic="true"
                          style="text-align:center; font-size: small;">
                    <p:panel id="dlRol" style="text-align:center; font-size: small;">
                        <p:panelGrid columns="2" rendered="#{not empty rolBean.rol}" 
                                     columnClasses="label,value" style="margin: 0 auto;">

                            <p:outputLabel value="Nombre" for="txtNombreRol"/>
                            <p:inputText id="txtNombreRol" value="#{rolBean.rol.nombre}" title="Nombre" 
                                         required="true" requiredMessage="El campo 'Nombre' es requerido" style="width: 200px"
                                         readonly="#{rolBean.soloLectura}" onkeyup="value=value.toUpperCase();"/>

                            <p:outputLabel value="Fecha de creación" rendered="#{rolBean.soloLectura}"/>
                            <p:inputText id="txtFechaCreacion" value="#{rolBean.rol.fechaCreacion}" style="width: 200px"
                                         readonly="#{rolBean.soloLectura}" rendered="#{rolBean.soloLectura}">
                                <f:convertDateTime type="date" locale="es_EC" timeZone="America/Guayaquil"  
                                                   dateStyle="default" pattern="yyyy/dd/MM HH:mm:ss" />
                            </p:inputText>

                            <p:outputLabel value="Estado" for="chkEstado" rendered="#{not rolBean.activarNuevo}"/>
                            <p:selectBooleanCheckbox id="chkEstado" value="#{rolBean.rol.estado}"
                                                     disabled="#{rolBean.soloLectura}" 
                                                     rendered="#{not rolBean.activarNuevo}"/>
                        </p:panelGrid>
                        <div align="right">
                            <p:outputLabel value = "* Campos Obligatorios"/>
                        </div>
                        
                        
                        <!--
                        <br/>
                        <p:dataTable id="dtAccesos" var="accesoItem" 
                                     rendered="#{not rolBean.activarNuevo}"
                                     value="#{rolBean.rol.accesoList}" 
                                     widgetVar="tablaAccesos"                                                                  
                                     emptyMessage="No existen datos"
                                     style="font-size: small;
                                     text-align: center; width: 50%; margin: 0 auto;"  
                                     paginator="true" rows="5"
                                     rowKey="#{accesoItem.codAcceso}">

                            <f:facet name="header">
                                <p:outputPanel>
                                    <h:outputText value="Buscar por todos los criterios:" />
                                    <p:inputText id="globalFilterAcceso" onkeyup="PF('tablaAccesos').filter()" 
                                                 style="width:200px" placeholder="Ingrese la palabra clave"/>
                                </p:outputPanel>
                            </f:facet> 

                            <p:column style="width:16px">
                                <p:rowToggler />
                            </p:column>

                            <p:column headerText="Nombre" filterBy="#{accesoItem.nombre}" sortBy="#{accesoItem.nombre}">
                                <p:outputLabel value="#{accesoItem.nombre}" style="text-align: center"/>
                            </p:column>

                            <p:rowExpansion>

                                <p:dataTable id="dtAcciones" var="accionItem" 
                                             value="#{rolBean.activarModificar ? accesoItem.accionList : rolBean.rol.accionList}"
                                             widgetVar="tablaAcciones" emptyMessage="No existen datos"
                                             selection="#{rolBean.rol.accionList}" 
                                             style="font-size: smaller; width: 50%; margin: 0 auto;"
                                             rowKey="#{accionItem.codAccion}" >

                                    <p:column selectionMode="multiple" rendered="#{rolBean.activarModificar}"
                                              style="width:16px;text-align:center;"/>

                                    <p:column headerText="Nombre">
                                        <p:outputLabel value="#{accionItem.nombre}"/>
                                    </p:column>
                                </p:dataTable>

                            </p:rowExpansion>

                        </p:dataTable>
                        -->
                        <br/>
                        <div align="center">
                            <p:commandButton rendered="#{rolBean.activarNuevo}" 
                                             update=":form:dtRoles,@form:dlDialog:dlRol"
                                             icon="ui-icon-disk"
                                             action="#{rolBean.guardar()}" 
                                             partialSubmit="true" process="@form:dlDialog"
                                             value="Guardar" >                                  
                                <p:confirm header="Confirmación" message="Esta seguro de guardar este registro?" icon="ui-icon-alert" />
                            </p:commandButton>                                
                        </div>
                        <div align="center">
                            <p:commandButton  rendered="#{rolBean.activarModificar}" 
                                              update=":form:dtRoles,@form:dlDialog:dlRol"
                                              icon="ui-icon-pencil"
                                              action="#{rolBean.modificar()}" 
                                              partialSubmit="true" process="@form:dlDialog"  
                                              value="Modificar">                                  
                                <p:confirm header="Confirmación" message="Esta seguro de modificar este registro?" icon="ui-icon-alert" />
                            </p:commandButton>                                  
                        </div> 
                    </p:panel>
                </p:dialog>
                <p:confirmDialog style="font-size: small" global="true" showEffect="fade" hideEffect="fade">
                    <p:commandButton value="Si" type="button" styleClass="ui-confirmdialog-yes" icon="ui-icon-check" />
                    <p:commandButton value="No" type="button" styleClass="ui-confirmdialog-no" icon="ui-icon-close" />
                </p:confirmDialog>
            </h:form>
        </ui:define>
    </ui:composition>
</html>
